Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
ilib-locale
Advanced tools
A BCP-47 locale specifier parser and validator. BCP-47 locale specifiers are also known as IETF locale tags.
npm install ilib-locale
# or
yarn add ilib-locale
Here is how you load ilib-locale:
//ES5
var Locale = require("ilib-locale");
var l = new Locale("ja-JP");
//ES6
import Locale from "ilib-locale";
var l = new Locale("ja-JP");
Here is how you use ilib-locale to parse locale specifiers:
var l = new Locale("zh-Hans-CN");
console.log("Language: " + l.getLanguage()); // outputs "zh"
console.log("Script: " + l.getScript()); // outputs "Hans"
console.log("Region: " + l.getRegion()); // outputs "CN"
Full documentation: Locale class
To get the default locale of the platform, simply make a new Locale instance without parameters.
var locale = new Locale();
console.log("Current locale is " + locale.getSpec()); // output "Current locale is en-US" in the US
This module uses ilib-env
to determine what the current platform is, and looks
in the appropriate place for the locale specifier. For most modern browsers and
recent versions of nodejs, this comes from the Intl
object, which retrieves
the locale from the environment variables or operating system.
If you have the locale parts and would like to construct a locale specifier, pass the parts to the constructor:
var language = "sr";
var script = "Cyrl";
var region = "SR";
var variant = "u-sort-old";
var locale = new Locale(language, region, variant, script);
console.log("Locale spec is " + locale.getSpec()); // output "Locale spec is sr-Cyrl-SR-u-sort-old"
If you have a string and you would like to validate that it forms a valid BCP-47 tag,
you can use the isValid
method to do that:
var l = new Locale("mn-XM");
console.log("Locale is valid: " + l.isValid());
// output "Locale is valid: false" because XM is not a valid region code
In order for a locale spec to be valid, each of its parts needs to conform to the codes in the ISO standard that governs that part:
Copyright © 2021-2025, JEDLSoft
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and limitations under the License.
See CHANGELOG.md
FAQs
A BCP-47/IETF locale specifier parser/validator
The npm package ilib-locale receives a total of 89 weekly downloads. As such, ilib-locale popularity was classified as not popular.
We found that ilib-locale demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.